package com.xigua.字符串;

import java.util.HashMap;

/**
 * @author LiRongHua
 * @Title: ${file_name}
 * @Package ${package_name}
 * @Description: 一位老师正在出一场由 n 道判断题构成的考试，每道题的答案为 true （用 'T' 表示）或者
 * false （用 'F' 表示）。老师想增加学生对自己做出答案的不确定性，方法是 最大化 
 * 有 连续相同 结果的题数。（也就是连续出现 true 或者连续出现 false）。
 *给你一个字符串 answerKey ，其中 answerKey[i] 是第 i 个问题的正确结果。除此以外，还给你一个整数 k ，表示你能进行以下操作的最多次数：
 *每次操作中，将问题的正确答案改为 'T' 或者 'F' （也就是将 answerKey[i] 改为 'T' 或者 'F' ）。
 *请你返回在不超过 k 次操作的情况下，最大 连续 'T' 或者 'F' 的数目。
 *
 *
 * @date 2022/3/2917:08
 */
public class _2024_考试的最大困扰度 {

    public static void main(String[] args) {
        maxConsecutiveAnswers("TFFT",1);
    }

    public static int maxConsecutiveAnswers(String answerKey, int k) {
        return Math.max(maxLength(answerKey,k,'T'),maxLength(answerKey,k,'F'));
    }

    public static int maxLength(String answerKey,int k ,Character c){
        int ans = 0;
        int j = 0;
        int count = 0;
        for (int i = 0; i < answerKey.length(); i++) {
            if (answerKey.charAt(i) == c) count++;
            while (count > k){
                if (answerKey.charAt(j)==c) count--;
                j++;
            }
            ans = Math.max(ans,i-j+1);
        }
        return ans;
    }

}
